[cosetta].vue 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. <script setup>
  2. const route = useRoute()
  3. const { $socket } = useNuxtApp()
  4. let { cosetta, comments } = reactive(await $fetch(`/api/cosetta/${route.params.cosetta}`))
  5. const comment = reactive({ cosetta_uuid: route.params.cosetta, message: '' })
  6. const addComment = async () => {
  7. const ret = await $fetch(`/api/comment`, { method: 'POST', body: { ...comment } })
  8. comment.message = ''
  9. const db_comment = await $fetch(`/api/comment/${ret.comment.uuid}`)
  10. comments.unshift(db_comment)
  11. $socket.emit("newComment", db_comment, route.params.cosetta )
  12. }
  13. onMounted(() => {
  14. $socket.emit("joinRoom", route.params.cosetta)
  15. $socket.on("newComment", (newComment) => {
  16. comments.unshift(newComment.message)
  17. })
  18. })
  19. </script>
  20. <template>
  21. <section class="bg-white py-8">
  22. <div class="container mx-auto pt-4 pb-12">
  23. <img v-if='cosetta.images' :src="`/imgs/${cosetta.images[0]}`" />
  24. <h2 class="text-pink-500 text-2xl card-title uppercase mb-2 divider" v-text='cosetta.name' />
  25. <div class="px-6 pt-4 pb-2">
  26. <span v-for='tag in cosetta.tags' :key='tag'
  27. class="inline-block bg-gray-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2"
  28. v-text='tag' />
  29. </div>
  30. <p class='pt-1 text-gray-700 text-xl'>{{ cosetta.description }}</p>
  31. </div>
  32. <div class="container mx-auto">
  33. <p class="font-bold text-xl uppercase">chiacchiere</p>
  34. <div class='form-control'>
  35. <div class='input-group'>
  36. <input v-model='comment.message' class="input input-bordered w-full text-sm" @keypress:enter="addComment" />
  37. <button class="btn btn-success" @click='addComment'>Invia</button>
  38. </div>
  39. <div class='mt-2' v-for='comment in comments' :key='comment.uuid'>
  40. <span class="label-text-alt" v-text='comment.updatedAt' />
  41. <div class="alert" v-text='comment.message' />
  42. </div>
  43. </div>
  44. </div>
  45. </section>
  46. </template>